<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro" xmlns:ry="">
	<head>
		<th:block th:include="include :: header('菜单列表')" />
		<style type="text/css">
		.bootstrap-tree-table .treetable-thead th {
			text-align: center;
		}
		</style>
	</head>
	<body class="gray-bg">
	    <div class="container-div">
			<div class="row">
				<div class="col-sm-12 search-collapse">
					<form id="menu-form">
						<div class="select-list">
							<ul>
								<li>
									菜单名称：<input type="text" name="menu_name"/>
								</li>
								<li>
									菜单状态：<ry:selectDict dictType="sys_show_hide" name="visible" headLabel="所有" headValue="" value=""/>
								</li>
								<li>
									<a class="btn btn-primary btn-rounded btn-sm" onclick="$.treeTable.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
									<a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
								</li>
							</ul>
						</div>
					</form>
				</div>

	            <div class="btn-group-sm" id="toolbar" role="group">
			        <a class="btn btn-success" onclick="$.operate.add(0)" shiro:hasPermission="system:menu:add">
	                    <i class="fa fa-plus"></i> 新增
	                </a>
	                <a class="btn btn-danger" onclick="authRole()" shiro:hasPermission="system:menu:authrole">
			            <i class="fa fa-info-circle"></i> 授权角色
			        </a>
	                <a class="btn btn-info" id="expandAllBtn">
	                    <i class="fa fa-exchange"></i> 展开/折叠
	                </a>
		        </div>
	       		 <div class="col-sm-12 select-table table-striped">
		            <table id="bootstrap-tree-table"></table>
		        </div>
		    </div>
		</div>

		<th:block th:include="include :: footer" />
		<script th:inline="javascript">
			var addFlag = [[${@permission.hasPermi('system:menu:add')}]];
			var editFlag = [[${@permission.hasPermi('system:menu:edit')}]];
			var removeFlag = [[${@permission.hasPermi('system:menu:remove')}]];
			var datas = [[${@dict.getType('sys_show_hide')}]];
			var prefix = ctx + "system/menu";

            $(function () {
                var options = {
                    code: "menu_id",
                    parentCode: "parent_id",
                    uniqueId: "menu_id",
                    expandAll: false,
                    expandFirst: false,
                    url: prefix + "/list",
                    createUrl: prefix + "/add/{id}",
                    updateUrl: prefix + "/edit/{id}",
                    removeUrl: prefix + "/remove/{id}",
                    modalName: "菜单",
                    columns: [{
                        field: 'selectItem',
                        radio: true
                    },
                        {
                            title: '菜单名称',
                            field: 'menu_name',
                            width: '20',
                            widthUnit: '%',
                            formatter: function (value, row, index) {
                                if ($.common.isEmpty(row.icon)) {
                                    return row.menu_name;
                                } else {
                                    return '<i class="' + row.icon + '"></i> <span class="nav-label">' + row.menu_name + '</span>';
                                }
                            }
                        },
                        {
                            field: 'url',
                            title: '请求地址',
                            width: '15',
                            widthUnit: '%',
                            align: "left",
                            formatter: function (value, row, index) {
                                return $.table.tooltip(value);
                            }
                        },
                        {
                            title: '类型',
                            field: 'menu_type',
                            width: '10',
                            widthUnit: '%',
                            align: "center",
                            formatter: function (value, item, index) {
                                if (item.menu_type == 'M') {
                                    return '<span class="label label-success">目录</span>';
                                } else if (item.menu_type == 'C') {
                                    return '<span class="label label-primary">菜单</span>';
                                } else if (item.menu_type == 'F') {
                                    return '<span class="label label-warning">权限</span>';
                                }
                            }
                        },
                        {
                            field: 'visible',
                            title: '可见',
                            width: '10',
                            widthUnit: '%',
                            align: "center",
                            formatter: function (value, row, index) {
                                if (row.menu_type == 'F') {
                                    return '-';
                                }
                                return $.table.selectDictLabel(datas, row.visible);
                            }
                        },
                        {
                            field: 'perms',
                            title: '权限标识',
                            width: '15',
                            widthUnit: '%',
                            align: "left",
                            formatter: function (value, row, index) {
                                return $.table.tooltip(value);
                            }
                        },
                        {
                            field: 'order_num',
                            title: '排序',
                            width: '10',
                            widthUnit: '%',
                            align: "center"
                        },
                        {
                            title: '操作',
                            width: '20',
                            widthUnit: '%',
                            align: "center",
                            formatter: function (value, row, index) {
                                var actions = [];
                                if (row.menu_type != 'F') {
                                    actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="javascript:void(0)" onclick="$.operate.edit(\'' + row.menu_id + '\')"><i class="fa fa-edit"></i>编辑</a> ');
                                    actions.push('<a class="btn btn-info btn-xs ' + addFlag + '" href="javascript:void(0)" onclick="$.operate.add(\'' + row.menu_id + '\')"><i class="fa fa-plus"></i>新增</a> ');
                                }
                                actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="$.operate.remove(\'' + row.menu_id + '\')"><i class="fa fa-trash"></i>删除</a>');
                                return actions.join('');
                            }
                        }]
                };
                $.treeTable.init(options);
            });

			/* 菜单管理-授权角色 */
			function authRole() {
			    var url = prefix + '/authRole';
			    $.modal.open("授权角色", url);
			}
		</script>
	</body>
</html>